<template>
  <!-- 最外层的大盒子 -->
  <div class="contain">
    <div class="box">     
        <!-- 滑动盒子 -->
        <div class="pre-box" :style="{'transform':flag?'translateX(100%)':'translateX(0%)',
        'background-color':flag?'#c9e0ed': '#edd4dc'   
    }">
            <h1>WELCOME</h1>
            <p>JOIN US!</p>
            <div class="img-box">
                <img :src=flag?wuwu:waoku>
            </div>
        </div>
        <!-- 注册盒子 -->
        <div class="register-form">
            <!-- 标题盒子 -->
            <div class="title-box">
                <h1>注册</h1>
            </div>
            <!-- 输入框盒子 -->
            <div class="input-box">
                <input type="text" placeholder="用户名" v-model="r_username">
                <input type="password" placeholder="密码" v-model="r_password">
                <input type="password" placeholder="确认密码" v-model="r_repassword">
            </div>
            <!-- 按钮盒子 -->
            <div class="btn-box">
                <button @click="register">注册</button>
                <!-- 绑定点击事件 -->
                <p @click="Reaccount">已有账号?去登录</p>
            </div>
            <hr>
            <!-- 提示 -->
            <div class="hint">{{ hint }}</div>
        </div>
        <!-- 登录盒子 -->
        <div class="login-form">
            <!-- 标题盒子 -->
            
            <div class="title-box">
                <h1>物联网监测平台登录</h1>
            </div>
            <!-- 输入框盒子 -->
            <div class="input-box">
                <input name="username" id="username" type="text" placeholder="用户名" v-model="username">
                <input name="password" id="password" type="password" placeholder="密码" v-model="password">
            </div>
            <!-- 按钮盒子 -->
            <div class="btn-box">
                <button id="btn" @click="LoginPost">登录</button>
                <!-- 绑定点击事件 -->
                <p @click="Resgist">没有账号?去注册</p>
            </div>
        </div>
       </div>
  </div>

</template>

<script>
import axios from 'axios';
import waoku from '../assets/img/waoku.jpg'
import wuwu from '../assets/img/wuwu.jpeg'
export default {
    name:'Login',
    components:{waoku,wuwu,axios},
    data(){
        return {
            // 滑块状态
            flag:false,
            // 图片显示
            waoku,
            wuwu,
            // 输入框
            username:'',
            password:'',
// 注册
            r_username:'',
            r_password:'',
            r_repassword:'',
            hint:''

            
        }
    },
    methods:{
        LoginPost(){
            console.log("test success!");
            // this.$router.push({path:"/ButtonNavbar"})
            // console.log(this.username+this.password);
            var datamain = JSON.stringify({
                "username":this.username,
                "password":this.password
            })
            axios({
                method:"post",
                url:"http://localhost:8088/init/Login",
                data:datamain,
                headers:{
                    'Content-Type':'application/json;charset=UTF-8'
                }
            }).then(resp=>{
                console.log(resp);
                console.log(resp.data.data);
                if(resp.data.data=='普通用户'||resp.data.data=='管理员'){
                    this.$router.push({
                    name:'Home',
                    query:{
                        "username":this.username,
                        "password":this.password,
                        "status":resp.data.data
                    }
                })
                }

            })
        },
        Resgist(){
             // 滑动的状态
            console.log("注册点击成功");
            this.flag = !this.flag  
        },
        // 已有账号
        Reaccount(){
            this.flag = !this.flag
        },

        // 注册
        register(){
            // 密码一致性验证
            if(this.r_password!=this.r_repassword){
                this.hint = "密码不一致"
            }
            // 密码长度验证
            else if(this.r_password.length<8 || this.r_password.length >16){
                this.hint = "请输入8至16位密码"
            }
            // 重名验证
            else{
                var datamain = JSON.stringify({
                "username":this.r_username,
                "password":this.r_password,
                "status":'普通用户'
            })
            // 后端发送请求
            axios({
                method:"post",
                url:"http://localhost:8088/init/Register",
                data:datamain,
                headers:{
                    'Content-Type':'application/json;charset=UTF-8'
                }
            }).then(resp=>{
                this.hint = resp.data.data;
                if(this.hint == "注册成功"){
                    this.$router.go(0)
                }
            })
            }
            console.log(this.r_username+this.r_password+this.r_repassword);
          
        }
    },

    mounted(){
        const bubleCreate=()=>{
                // 获取body元素
                const body = document.body
                // 创建泡泡元素
                const buble = document.createElement('span')
                // 设置泡泡半径
                let r = Math.random()*5 + 25 //半径大小为25~30
                // 设置泡泡的宽高
                buble.style.width=r+'px'
                buble.style.height=r+'px'
                // 设置泡泡的随机起点
                buble.style.left=Math.random()*innerWidth+'px'
                // 为body添加buble元素
                body.append(buble)
                // 4s清除一次泡泡
                setTimeout(()=>{
                    buble.remove()
                },4000)
            }

             // 每200ms生成一个泡泡
             let paopao =setInterval(() => {
                bubleCreate()
            }, 500);
    }

}
</script>

<style>

* {
    /* 去除浏览器默认内外边距 */
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* 去除input的轮廓 */
input {
    outline: none;
}

/* html,
body {
    height: 100%;
} */
.contain{
    width: 100%;
    height: 100%;
}
body {
    /* 溢出隐藏 */
    overflow-x: hidden;
    display: flex;
    /* 渐变方向从左到右 */
    background: linear-gradient(to right, rgb(247, 209, 215), rgb(191, 227, 241));
}

span {
    position: absolute;
    z-index: 0;
    bottom: 0;
    border-radius: 50%;
    /* 径向渐变 */
    background: radial-gradient(circle at 72% 28%, #fff 3px, #ff7edf 8%, #5b5b5b, #aad7f9 100%);
    /* 泡泡内阴影 */
    box-shadow: inset 0 0 6px #fff,
        inset 3px 0 6px #eaf5fc,
        inset 2px -2px 10px #efcde6,
        inset 0 0 60px #f9f6de,
        0 0 20px #fff;
    /* 动画 */
    animation: myMove 4s linear infinite;
}


@keyframes myMove {
    0% {
        transform: translateY(0%);
        opacity: 1;
    }

    50% {
        transform: translate(10%, -1000%);
    }

    75% {
        transform: translate(-20%, -1200%);
    }

    99% {
        opacity: .9;
    }

    100% {
        transform: translateY(-1800%) scale(1.5);
        opacity: 0;
    }
}

/* 最外层的大盒子 */
.box {
    width: 1050px;
    height: 600px;
    display: flex;
    /* 相对定位 */
    position: relative;
    z-index: 2;
    margin: auto;
    /* 设置圆角 */
    border-radius: 8px;
    /* 设置边框 */
    border: 1px solid rgba(255, 255, 255, .6);
    /* 设置盒子阴影 */
    box-shadow: 2px 1px 19px rgba(0, 0, 0, .1);
}

/* 滑动的盒子 */
.pre-box {
    /* 宽度为大盒子的一半 */
    width: 50%;
    /* width: var(--width); */
    height: 100%;
    /* 绝对定位 */
    position: absolute;
    /* 距离大盒子左侧为0 */
    left: 0;
    /* 距离大盒子顶部为0 */
    top: 0;
    z-index: 99;
    border-radius: 4px;
    background-color: #edd4dc;
    box-shadow: 2px 1px 19px rgba(0, 0, 0, .1);
    /* 动画过渡，先加速再减速 */
    transition: 0.5s ease-in-out;
}

/* 滑动盒子的标题 */
.pre-box h1 {
    margin-top: 150px;
    text-align: center;
    /* 文字间距 */
    letter-spacing: 5px;
    color: white;
    /* 禁止选中 */
    user-select: none;
    /* 文字阴影 */
    text-shadow: 4px 4px 3px rgba(0, 0, 0, .1);
}

/* 滑动盒子的文字 */
.pre-box p {
    height: 30px;
    line-height: 30px;
    text-align: center;
    margin: 20px 0;
    /* 禁止选中 */
    user-select: none;
    font-weight: bold;
    color: white;
    text-shadow: 4px 4px 3px rgba(0, 0, 0, .1);
}

/* 图片盒子 */
.img-box {
    width: 200px;
    height: 200px;
    margin: 20px auto;
    /* 设置为圆形 */
    border-radius: 50%;
    /* 设置用户禁止选中 */
    user-select: none;
    overflow: hidden;
    box-shadow: 4px 4px 3px rgba(0, 0, 0, .1);
}

/* 图片 */
.img-box img {
    width: 100%;
    transition: 0.5s;
}

/* 登录和注册盒子 */
.login-form,
.register-form {
    flex: 1;
    height: 100%;
}

/* 标题盒子 */
.title-box {
    height: 300px;
    line-height: 500px;

}


/* 标题 */
.title-box h1 {
    text-align: center;
    color: white;
    /* 禁止选中 */
    user-select: none;
    letter-spacing: 5px;
    text-shadow: 4px 4px 3px rgba(0, 0, 0, .1);

}

/* 输入框盒子 */
.input-box {
    display: flex;
    /* 纵向布局 */
    flex-direction: column;
    /* 水平居中 */
    align-items: center;
}

/* 输入框 */
input {
    width: 60%;
    height: 40px;
    margin-bottom: 20px;
    text-indent: 10px;
    border: 1px solid #fff;
    background-color: rgba(255, 255, 255, 0.3);
    border-radius: 120px;
    /* 增加磨砂质感 */
    backdrop-filter: blur(10px);
}

input:focus {
    /* 光标颜色 */
    color: #b0cfe9;

}

/* 聚焦时隐藏文字 */
input:focus::placeholder {
    opacity: 0;
}

/* 按钮盒子 */
.btn-box {
    display: flex;
    justify-content: center;
}

/* 按钮 */
button {
    width: 100px;
    height: 30px;
    margin: 0 7px;
    line-height: 30px;
    border: none;
    border-radius: 4px;
    background-color: #69b3f0;
    color: white;
}

/* 按钮悬停时 */
button:hover {
    /* 鼠标小手 */
    cursor: pointer;
    /* 透明度 */
    opacity: .8;
}

/* 按钮文字 */
.btn-box p {
    height: 30px;
    line-height: 30px;
    /* 禁止选中 */
    user-select: none;
    font-size: 14px;
    color: white;

}

.btn-box p:hover {
    cursor: pointer;
    border-bottom: 1px solid white;
}


</style>